<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8" />
    <title>JavaScript简易日历</title>
    <style type="text/css">
        * {
            padding: 0;
            margin: 0;
        }

        li {
            list-style: none;
        }

        body {
            background: #f6f9fc;
            font-family: arial;
        }

        .calendar {
            width: 210px;
            margin: 0 auto;
            padding: 10px 10px 20px 20px;
            background: #eae9e9;
        }

        .calendar ul {
            width: 210px;
            overflow: hidden;
            padding-bottom: 10px;
        }

        .calendar li {
            float: left;
            width: 58px;
            height: 54px;
            margin: 10px 10px 0 0;
            border: 1px solid #fff;
            background: #424242;
            color: #fff;
            text-align: center;
            cursor: pointer;
        }

        .calendar li h2 {
            font-size: 20px;
            padding-top: 5px;
        }

        .calendar li p {
            font-size: 14px;
        }

        .calendar .active {
            border: 1px solid #424242;
            background: #fff;
            color: #e84a7e;
        }

        .calendar .active p {
            font-weight: bold;
        }

        .calendar .text {
            width: 178px;
            padding: 0 10px 10px;
            border: 1px solid #fff;
            padding-top: 10px;
            background: #f1f1f1;
            color: #555;
        }

        .calendar .text h2 {
            font-size: 14px;
            margin-bottom: 10px;
        }

        .calendar .text p {
            font-size: 12px;
            line-height: 18px;
        }
    </style>

</head>

<body>

    <div id="tab" class="calendar">

        <ul id="box">
            <li class="active">
                <h2>1</h2>
                <p>JAN</p>
            </li>
            <li>
                <h2>2</h2>
                <p>FER</p>
            </li>
            <li>
                <h2>3</h2>
                <p>MAR</p>
            </li>
            <li>
                <h2>4</h2>
                <p>APR</p>
            </li>
            <li>
                <h2>5</h2>
                <p>MAY</p>
            </li>
            <li>
                <h2>6</h2>
                <p>JUN</p>
            </li>
            <li>
                <h2>7</h2>
                <p>JUL</p>
            </li>
            <li>
                <h2>8</h2>
                <p>AUG</p>
            </li>
            <li>
                <h2>9</h2>
                <p>SEP</p>
            </li>
            <li>
                <h2>10</h2>
                <p>OCT</p>
            </li>
            <li>
                <h2>11</h2>
                <p>NOV</p>
            </li>
            <li>
                <h2>12</h2>
                <p>DEC</p>
            </li>
        </ul>

        <div class="text" id="txt">
            <h2>1月活动</h2>
            <p>快过年了，大家可以商量着去哪玩吧～</p>
        </div>

    </div>
    <script type="text/javascript">

        /*
            1- 所有月 被点击的时候，都有选中样式
                遍历所有的月所在的li-添加点击事件，点击的时候，让点击的li，添加一个类 active
            2-改变h2内容    点击的li 有下标 0开始  0+1 

            3- 定义 数组存入每个月的活动
        
        */

        var arr = ['xxx', '223', '333', '3444', '555', '66', '777', '爬山', '999', '100', '111', '21']
        // 1-遍历所有的月所在的li-添加点击事件，
        var liArr = document.querySelectorAll('#box li');
        liArr.forEach(function (li, i) {
            li.onclick = function () {
                // li this都是 指的是 我们点击的那个li -i 是 点击li的对应下标
                console.log(li, i, '点击了li', this);

                // 让点击的li，添加一个类 active
                // 遍历所有li，去掉他们的类名
                liArr.forEach(function (v) { v.className = '' })
                li.className = 'active'

                //  2-改变h2内容    点击的li 有下标 0开始  0+1 
                var month = i + 1;
                var str = month + '月活动';
                console.log(str);

                // 获取 h2标签
                var h2 = document.querySelector('.text h2');
                console.log(h2);
                // Cannot set properties of null (setting 'innerHTML')
                // 不能设置 null的（innerHTML）属性
                h2.innerHTML = str

                // 根据月份的下标 去数组取出对应月份的活动--获取 p标签，设置内容
                var p = document.querySelector('.text p');
                p.innerHTML = arr[i];
            }
        })



    </script>
</body>

</html>